<template>
  <div class="reportFormPage">
    <div class="report-dom">
      <el-row>
        <el-col :span="5" :offset="19">
          <div class="pageNumBox">
            <span>第</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.page }}&nbsp;</span>
            <span>页，共</span>
            <span class="placeholder-min text-center">&nbsp;{{ form.totalPage }}&nbsp;</span>
            <span>页</span>
          </div>
        </el-col>
      </el-row>
      <div class="topTwoBox">
        <div class="centerName">路面厚度、芯样完整性试验检测记录表(钻芯法)</div>
        <div class="codeText">
          <tr>
            JGLP01012
          </tr>
        </div>
      </div>
      <div class="threeTopBox">
        <div class="left-border">
          <div class="box-title">检测单位名称：</div>
          <div class>{{ form.jiancdwmc }}</div>
        </div>
        <div class="right-border">
          <span>记录编号：</span>
          <span class="placeholder">{{ form.jilbh }}</span>
        </div>
      </div>
      <div class="table-border">
        <!-- .........................1111111111111111111111111111111......................................................... -->
        <table height="220px" class="top-table">
          <tbody>
            <tr>
              <td height="30" align="center" width="15%">
                <span>工程名称</span>
              </td>
              <td colspan="3">
                <span>{{ form.gongcmc }}</span>
              </td>
            </tr>
            <tr>
              <td height="30" width="15%">
                <span>工程部位/用途</span>
              </td>
              <td colspan="3">
                <span>{{ form.gongcbwyt }}</span>
              </td>
            </tr>
            <tr>
              <td height="50" align="center">样品信息</td>
              <td class="specimen-border" colspan="3">
                <span>样品名称：</span>
                <span :class="{ placeholder: !form.yangpmc }">{{ form.yangpmc }}</span>
                <span>；样品编号：</span>
                <span :class="{ 'placeholder-long': !form.yangpbh }">{{ form.yangpbh }}</span>
                <span>；样品数量：</span>
                <span :class="{ placeholder: !form.yangpsl }">{{ form.yangpsl }}</span>
                <span>；样品状态：</span>
                <span :class="{ placeholder: !form.yangpzt }">{{ form.yangpzt }}</span>
                <span>；来样时间：</span>
                <span :class="{ placeholder: !form.yangpsj }">{{ form.yangpsj }}</span>
              </td>
            </tr>
            <tr>
              <td height="25" align="center" width="15%">
                <span style="width: 90px; display: inline-block">试验检测日期</span>
              </td>
               <!-- <td width="35%" class="text-center">{{ form.shiyjcrq }}</td> -->                                            
 <td width="35%" class="text-center">
      <el-input v-model="form.shiyjcrq" />
</td>
              <td align="center" width="15%">
                <span style="width: 90px; display: inline-block">试验条件</span>
              </td>
              <td v-if="isPdf" width="35%">
                温度：
                <span style="display: inline-block; width: 10%">{{ form.shiytjwd }}</span>
                ℃；湿度：
                <span style="display: inline-block; width: 10%">{{ form.shiytjsd }}</span
                >%RH
              </td>
              <td v-else width="35%">
                温度：
                <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjwd" style="width: 15%" />℃；湿度：
                <el-input :type="isPdf ? 'string' : 'number'" v-model="form.shiytjsd" style="width: 15%" />%RH
              </td>
            </tr>
            <tr>
              <td height="50" align="center" width="15%">
                <span style="width: 90px; display: inline-block">检测依据</span>
              </td>
              <td width="35%">
                <span v-if="isPdf">{{ form.jiancyj }}</span>
                <el-input v-else type="textarea" v-model="form.jiancyj" :rows="2" class="mark" @dblclick.native="showBsJiancyjView" readonly />
              </td>
              <td align="center" width="15%">
                <span style="width: 90px; display: inline-block">判定依据</span>
              </td>
              <td width="35%">
                <span v-if="isPdf">{{ form.pandyj }}</span>
                <el-input v-else type="textarea" v-model="form.pandyj" :rows="2" @dblclick.native="showBsJudgeBaseView" @focus="handleFocus('pandyj')" class="mark" />
              </td>
            </tr>
            <tr class="bottom-border">
              <td height="50" align="center">
                <div>主要仪器设备</div>
                <div>名称及编号</div>
              </td>
              <td colspan="3">
                <span v-if="isPdf">{{ form.zhuyyqsbmcjbh }}</span>
                <el-input v-else type="textarea" :rows="2" v-model="form.zhuyyqsbmcjbh" class="height100 width100 mark" @dblclick.native="showBsInstrumentView" readonly></el-input>
              </td>
            </tr>
          </tbody>
        </table>
        <!-- .................................22222222222222222222222222222222............................................... -->
        <table height="30px" class="middle-table">
          <tr>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">结构层</span>
            </td>
            <td width="35%" class="text-center">
              <el-input type="text" v-model="form.jiegc" @blur="setHdxywzxBgData()" @keydown.native="handleKeyDown($event, 0, 0)" :ref="'0_0'" />
            </td>
            <td align="center" width="15%">
              <span style="width: 90px; display: inline-block">厚度设计值</span>
            </td>
            <td width="35%" class="text-center">
              <el-input :type="isPdf ? 'string' : 'number'" v-model="form.houdsjz" @blur="setHdxywzxBgData()" @keydown.native="handleKeyDown($event, 0, 1)" :ref="'0_1'" />
            </td>
          </tr>
        </table>
        <table height="580px" class="middle-table">
          <tbody>
            <tr height="25">
              <td rowspan="2">试样编号</td>
              <td rowspan="2">取样日期</td>
              <td rowspan="2">取样桩号及位置</td>
              <td colspan="5">芯样长度(mm)</td>
              <td rowspan="2">芯样情况描述</td>
            </tr>
            <tr height="25">
              <td>1</td>
              <td>2</td>
              <td>3</td>
              <td>4</td>
              <td>平均</td>
            </tr>
            <tr height="25" v-if="index < 10" v-for="(item, index) in form.detailList" :key="index">
              <td class="td1">
                <el-input type="text" v-model="item.shiybh" @keydown.native="handleKeyDown($event, index + 1, 0)" :ref="`${index + 1}_0`" />
              </td>
              <td class="td2">
                <span v-if="isPdf">{{ item.qvyrq }}</span>
                <el-date-picker v-else v-model="item.qvyrq" type="date" class="hide-icon width100" format="yyyy-MM-dd" value-format="yyyy-MM-dd"></el-date-picker>
              </td>
              <td class="td3">
                <el-input type="text" v-model="item.qvyzhjwz" @blur="setHdxywzxBgData()" @keydown.native="handleKeyDown($event, index + 1, 1)" :ref="`${index + 1}_1`" />
              </td>
              <td class="td1">
                <el-input :type="isPdf ? 'string' : 'number'" v-model="item.changd1" @blur="calculatePingjz(index)" @keydown.native="handleKeyDown($event, index + 1, 2)" :ref="`${index + 1}_2`" />
              </td>
              <td class="td1">
                <el-input :type="isPdf ? 'string' : 'number'" v-model="item.changd2" @blur="calculatePingjz(index)" @keydown.native="handleKeyDown($event, index + 1, 3)" :ref="`${index + 1}_3`" />
              </td>
              <td class="td1">
                <el-input :type="isPdf ? 'string' : 'number'" v-model="item.changd3" @blur="calculatePingjz(index)" @keydown.native="handleKeyDown($event, index + 1, 4)" :ref="`${index + 1}_4`" />
              </td>
              <td class="td1">
                <el-input :type="isPdf ? 'string' : 'number'" v-model="item.changd4" @blur="calculatePingjz(index)" @keydown.native="handleKeyDown($event, index + 1, 5)" :ref="`${index + 1}_5`" />
              </td>
              <td class="td1">
                <el-input :type="isPdf ? 'string' : 'number'" v-model="item.pingj" disabled />
              </td>
              <td class="td4">
                <span v-if="isPdf">{{ item.xinyqkms }}</span>
                <el-input v-else type="textarea" :rows="2" v-model="item.xinyqkms" @blur="setHdxywzxBgData()" @keydown.native="handleKeyDown($event, index + 1, 6)" :ref="`${index + 1}_6`"></el-input>
              </td>
            </tr>
            <!-- <tr height="25">
              <td rowspan="3">计算</td>
              <td colspan="4">
                1、代表值容许偏差=
                <span v-if="isPdf" class="bottom-input">{{ form.daibzrxpc }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.daibzrxpc" style="width: 40px" />mm；
              </td>
              <td colspan="4">
                单点合格值容许偏差=
                <span v-if="isPdf" class="bottom-input">{{ form.dandhgzrxpc }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.dandhgzrxpc" style="width: 40px" />mm
              </td>
            </tr>
            <tr height="25">
              <td colspan="4">
                2、厚度平均值=
                <span v-if="isPdf" class="bottom-input">{{ form.houdpjz }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.houdpjz" style="width: 40px" /> mm；
              </td>
              <td colspan="4">
                标准差S=
                <span v-if="isPdf" class="bottom-input">{{ form.biaozc }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.biaozc" style="width: 40px" /> mm
              </td>
            </tr>
            <tr height="25">
              <td colspan="4">
                3、厚度代表值XL=
                <span v-if="isPdf" class="bottom-input">{{ form.houddbz }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.houddbz" style="width: 40px" /> mm
              </td>
              <td colspan="4">
                保证率=
                <span v-if="isPdf" class="bottom-input">{{ form.baozl }}</span>
                <el-input v-else :type="isPdf ? 'string' : 'number'" v-model="form.baozl" style="width: 40px" /> %
              </td>
            </tr> -->
          </tbody>
        </table>
        <!-- .....................................................33333333333333333................................................... -->
        <table height="60px" class="bottom-table">
          <tr>
            <td>
              <span v-if="isPdf" class="textarea-span">{{ form.fujsm }}</span>
              <el-input v-else type="textarea" :rows="2" v-model="form.fujsm" @focus="handleFocus('fujsm')" />
            </td>
          </tr>
        </table>
      </div>
      <!-- .................................44444444444............................................. -->
      <table height="22px" class="transparent">
        <tbody>
          <tr>
            <td width="10%" align="right">检测：</td>
            <td width="15%" align="left"></td>
            <td width="10%" align="right">记录：</td>
            <td width="15%" align="left"></td>
            <td width="10%" align="right">复核：</td>
            <td align="left" width="15%"></td>
            <td width="10%">日期：</td>
            <td align="left" width="15%">
              <div style="display: inline-block; margin-left: 20px">年</div>
              <div style="display: inline-block; margin-left: 20px">月</div>
              <div style="display: inline-block ;margin-left: 20px">日</div>
            </td>
          </tr>
        </tbody>
      </table>
    </div>
    <bs-instrument-view ref="bsInstrumentViewRef" @select="selectInstrument"></bs-instrument-view>
    <bs-jiancyj-view ref="bsJiancyjViewRef" @select="selectJiancyj" :syType="syType"></bs-jiancyj-view>
    <bs-judge-base-view ref="bsJudgeBaseViewRef" @select="selectJudge" :syType="syType"></bs-judge-base-view>
  </div>
</template>

<script>
import { getHdxywzxjlbBsInfo } from "@/api/report_ljlm/hdxywzxjlbBsInfo";
import BsInstrumentView from "@/views/dept/bsInstrument/BsInstrumentView.vue";
import BaQjDetailView from "@/views/sycs/baQjDetail/BaQjDetailView.vue";
import BsJiancyjView from "@/views/sycs/bsJiancyj/BsJiancyjView.vue";
import BsJudgeBaseView from "@/views/sycs/bsJudgeBase/BsJudgeBaseView.vue";

import decimal from "@/utils/big-decimal";
import { handleFocus, emptyConvert, calculateMeanvalue, calculateStandardDeviation, handleKeyDown } from "@/views/reportForms/utils";
import Bus from "@/utils/bus";
export default {
  name: "hdxywzxjlb",
  components: {
    BsInstrumentView,
    BaQjDetailView,
    BsJiancyjView,
    BsJudgeBaseView
  },
  props: {
    excelId: {
      type: [String, Number],
      default: () => ""
    },
    syType: {
      type: [String, Number],
      default: () => ""
    },
    page: {
      type: Number,
      default: () => 0
    },
    isPdf: {
      type: Boolean,
      default: () => false
    },
    printEmpty: {
      type: Boolean,
      default: () => false
    }
  },
  data() {
    return {
      params: {},
      query: {},
      // 表单参数
      form: {
        detailList: [{}, {}, {}, {}, {}, {}, {}, {}, {}, {}]
      }
    };
  },
  watch: {
    isPdf(newVal, oldVal) {
      this.form = { ...emptyConvert(this.form, newVal) };
    }
  },
  created() {
    this.getInfo();
  },
  methods: {
    // 获取详情
    getInfo() {
      if (!this.excelId) {
        const { jiancdwmc, gongcmc } = this.$store.state.dept.deptInfo;
        this.form.jiancdwmc = jiancdwmc;
        this.form.gongcmc = gongcmc;
        this.form.fujsm = "附加声明：";
        return;
      }
      getHdxywzxjlbBsInfo(this.excelId).then((response) => {
        this.form = response.data;
        if (!this.form.fujsm) {
          this.form.fujsm = "附加声明：";
        }
      });
    },
    // 显示检测依据列表
    showBsJiancyjView() {
      this.$refs.bsJiancyjViewRef.init(this.form.jiancyjIds);
    },
    // 检测依据选择
    selectJiancyj(info) {
      this.form.jiancyj = info.label;
      this.form.jiancyjIds = info.ids;
      Bus.$emit("setHdxywzxBgJiancyj", { jiancyj: this.form.jiancyj, jiancyjIds: this.form.jiancyjIds });
    },
    // 显示判定依据列表
    showBsJudgeBaseView() {
      this.$refs.bsJudgeBaseViewRef.init(this.form.pandyjIds);
    },
    // 判断依据选择
    selectJudge(info) {
       this.form.pandyjIds = info.ids;
      this.form.pandyj = info.label;
    },
    // 显示仪器列表
    showBsInstrumentView() {
      this.$refs.bsInstrumentViewRef.init(this.form.shebIds);
    },
    // 仪器选择
    selectInstrument(info) {
      this.form.zhuyyqsbmcjbh = info.label;
      this.form.shebIds = info.ids;
      Bus.$emit("setHdxywzxBgZhuyyqsbmcjbh", { zhuyyqsbmcjbh: this.form.zhuyyqsbmcjbh, shebIds: this.form.shebIds });
    },
    // 计算平均值
    calculatePingjz(index) {
      let arr = [];
      for (let i = 1; i <= 4; i++) {
        const a = this.form.detailList[index]["changd" + i];
        if (a) {
          arr.push(a);
        }
      }
      let pingjz = null;
      if (arr.length > 0) {
        pingjz = calculateMeanvalue(arr, 0);
      }
      this.form.detailList[index].pingj = pingjz;
      this.setHdxywzxBgData();
      // this.calculateHoudpjz();
    },
    // 计算厚度平均值
    calculateHoudpjz() {
      let arr = [];
      this.form.detailList.forEach((item) => {
        if (item.pingj) {
          arr.push(item.pingj);
        }
      });
      let houdpjz = null;
      let biaozc = null;
      if (arr.length > 1) {
        // 平均值
        houdpjz = calculateMeanvalue(arr, 0);
        // 标准差
        biaozc = calculateStandardDeviation(arr);
      }
      this.form.houdpjz = houdpjz;
      this.form.biaozc = biaozc;
      // 计算代表值
      this.calculateSaibz();
    },
    // 代表值
    calculateSaibz() {
      // 平均值-（1.374*标准差）
      const V = this.form.houdpjz; // 平均值
      const W = this.form.biaozc; //  标准差
      let sum = null;
      if (V && W) {
        sum = decimal.subtract(V, decimal.multiply(1.374, W, 8), 0);
      }
      this.form.houddbz = sum;
      this.setHdxywzxBgData();
    },
    // 给报告传值
    setHdxywzxBgData() {
      const arr = this.form.detailList.map((item) => {
        const info = {
          zhuangh: item.qvyzhjwz,
          jiegc: item.pingj ? this.form.jiegc : null,
          shejhd: item.pingj ? this.form.houdsjz : null,
          shichd: item.pingj,
          xinywzx: item.xinyqkms
        };
        return info;
      });

      Bus.$emit("setHdxywzxBgData" + this.page, arr);
    },
    submitForm() {
      return this.form;
    },
    handleFocus(event) {
      handleFocus(event, this.page, this.form[event]);
    },
    handleKeyDown(event, rowIndex, colIndex) {
      const maxArr = [1, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6];
      const ref = handleKeyDown(event, rowIndex, colIndex, maxArr);
      if (this.$refs[ref]?.length) {
        this.$refs[ref][0].focus();
      } else if (this.$refs[ref]) {
        this.$refs[ref].focus();
      }
    }
  }
};
</script>

<style scoped>
.td1 {
  width: calc(100% / 15 * 1);
}

.td2 {
  width: calc(100% / 15 * 2);
}

.td3 {
  width: calc(100% / 15 * 3);
}

.td4 {
  width: calc(100% / 15 * 4);
}

.bottom-input {
  display: inline-block;
  width: 40px;
}
</style>
